/**
 * Copyright (c) Tiny Technologies, Inc. All rights reserved.
 * Licensed under the LGPL or a commercial license.
 * For LGPL see License.txt in the project root for license information.
 * For commercial licenses see https://www.tiny.cloud/
 *
 * Version: 5.8.2 (2021-06-23)
 */
(function () {
  'use strict'

  var global = tinymce.util.Tools.resolve('tinymce.PluginManager')

  var noop = function () {
  }
  var constant = function (value) {
    return function () {
      return value
    }
  }
  var never = constant(false)
  var always = constant(true)

  var none = function () {
    return NONE
  }
  var NONE = (function () {
    var eq = function (o) {
      return o.isNone()
    }
    var call = function (thunk) {
      return thunk()
    }
    var id = function (n) {
      return n
    }
    var me = {
      fold: function (n, _s) {
        return n()
      },
      is: never,
      isSome: never,
      isNone: always,
      getOr: id,
      getOrThunk: call,
      getOrDie: function (msg) {
        throw new Error(msg || 'error: getOrDie called on none.')
      },
      getOrNull: constant(null),
      getOrUndefined: constant(undefined),
      or: id,
      orThunk: call,
      map: none,
      each: noop,
      bind: none,
      exists: never,
      forall: always,
      filter: none,
      equals: eq,
      equals_: eq,
      toArray: function () {
        return []
      },
      toString: constant('none()')
    }
    return me
  }())
  var some = function (a) {
    var constant_a = constant(a)
    var self = function () {
      return me
    }
    var bind = function (f) {
      return f(a)
    }
    var me = {
      fold: function (n, s) {
        return s(a)
      },
      is: function (v) {
        return a === v
      },
      isSome: always,
      isNone: never,
      getOr: constant_a,
      getOrThunk: constant_a,
      getOrDie: constant_a,
      getOrNull: constant_a,
      getOrUndefined: constant_a,
      or: self,
      orThunk: self,
      map: function (f) {
        return some(f(a))
      },
      each: function (f) {
        f(a)
      },
      bind: bind,
      exists: bind,
      forall: bind,
      filter: function (f) {
        return f(a) ? me : NONE
      },
      toArray: function () {
        return [a]
      },
      toString: function () {
        return 'some(' + a + ')'
      },
      equals: function (o) {
        return o.is(a)
      },
      equals_: function (o, elementEq) {
        return o.fold(never, function (b) {
          return elementEq(a, b)
        })
      }
    }
    return me
  }
  var from = function (value) {
    return value === null || value === undefined ? NONE : some(value)
  }
  var Optional = {
    some: some,
    none: none,
    from: from
  }

  var get = function (xs, i) {
    return i >= 0 && i < xs.length ? Optional.some(xs[i]) : Optional.none()
  }
  var head = function (xs) {
    return get(xs, 0)
  }

  var global$1 = tinymce.util.Tools.resolve('tinymce.dom.DOMUtils')

  var isCodeSample = function (elm) {
    return elm && elm.nodeName === 'PRE' && elm.className.indexOf('language-') !== -1
  }
  var trimArg = function (predicateFn) {
    return function (arg1, arg2) {
      return predicateFn(arg2)
    }
  }

  var Global = typeof window !== 'undefined' ? window : Function('return this;')()

  var exports$1 = {}; var module = { exports: exports$1 }; var global$2 = {};
  (function (define, exports, module, require) {
    var oldprism = window.Prism
    window.Prism = { manual: true };
    (function (f) {
      if (typeof exports === 'object' && typeof module !== 'undefined') {
        module.exports = f()
      } else if (typeof define === 'function' && define.amd) {
        define([], f)
      } else {
        var g
        if (typeof window !== 'undefined') {
          g = window
        } else if (typeof global$2 !== 'undefined') {
          g = global$2
        } else if (typeof self !== 'undefined') {
          g = self
        } else {
          g = this
        }
        g.EphoxContactWrapper = f()
      }
    }(function () {
      return (function () {
        function r (e, n, t) {
          function o (i, f) {
            if (!n[i]) {
              if (!e[i]) {
                var c = typeof require === 'function' && require
                if (!f && c) { return c(i, !0) }
                if (u) { return u(i, !0) }
                var a = new Error('Cannot find module \'' + i + '\'')
                throw a.code = 'MODULE_NOT_FOUND', a
              }
              var p = n[i] = { exports: {} }
              e[i][0].call(p.exports, function (r) {
                var n = e[i][1][r]
                return o(n || r)
              }, p, p.exports, r, e, n, t)
            }
            return n[i].exports
          }
          for (var u = typeof require === 'function' && require, i = 0; i < t.length; i++) { o(t[i]) }
          return o
        }
        return r
      }())({
        1: [
          function (require, module, exports) {
            Prism.languages.c = Prism.languages.extend('clike', {
              comment: {
                pattern: /\/\/(?:[^\r\n\\]|\\(?:\r\n?|\n|(?![\r\n])))*|\/\*[\s\S]*?(?:\*\/|$)/,
                greedy: true
              },
              'class-name': {
                pattern: /(\b(?:enum|struct)\s+(?:__attribute__\s*\(\([\s\S]*?\)\)\s*)?)\w+|\b[a-z]\w*_t\b/,
                lookbehind: true
              },
              keyword: /\b(?:__attribute__|_Alignas|_Alignof|_Atomic|_Bool|_Complex|_Generic|_Imaginary|_Noreturn|_Static_assert|_Thread_local|asm|typeof|inline|auto|break|case|char|const|continue|default|do|double|else|enum|extern|float|for|goto|if|int|long|register|return|short|signed|sizeof|static|struct|switch|typedef|union|unsigned|void|volatile|while)\b/,
              function: /[a-z_]\w*(?=\s*\()/i,
              number: /(?:\b0x(?:[\da-f]+(?:\.[\da-f]*)?|\.[\da-f]+)(?:p[+-]?\d+)?|(?:\b\d+(?:\.\d*)?|\B\.\d+)(?:e[+-]?\d+)?)[ful]{0,4}/i,
              operator: />>=?|<<=?|->|([-+&|:])\1|[?:~]|[-+*/%&|^!=<>]=?/
            })
            Prism.languages.insertBefore('c', 'string', {
              macro: {
                pattern: /(^\s*)#\s*[a-z](?:[^\r\n\\/]|\/(?!\*)|\/\*(?:[^*]|\*(?!\/))*\*\/|\\(?:\r\n|[\s\S]))*/im,
                lookbehind: true,
                greedy: true,
                alias: 'property',
                inside: {
                  string: [
                    {
                      pattern: /^(#\s*include\s*)<[^>]+>/,
                      lookbehind: true
                    },
                    Prism.languages.c.string
                  ],
                  comment: Prism.languages.c.comment,
                  'macro-name': [
                    {
                      pattern: /(^#\s*define\s+)\w+\b(?!\()/i,
                      lookbehind: true
                    },
                    {
                      pattern: /(^#\s*define\s+)\w+\b(?=\()/i,
                      lookbehind: true,
                      alias: 'function'
                    }
                  ],
                  directive: {
                    pattern: /^(#\s*)[a-z]+/,
                    lookbehind: true,
                    alias: 'keyword'
                  },
                  'directive-hash': /^#/,
                  punctuation: /##|\\(?=[\r\n])/,
                  expression: {
                    pattern: /\S[\s\S]*/,
                    inside: Prism.languages.c
                  }
                }
              },
              constant: /\b(?:__FILE__|__LINE__|__DATE__|__TIME__|__TIMESTAMP__|__func__|EOF|NULL|SEEK_CUR|SEEK_END|SEEK_SET|stdin|stdout|stderr)\b/
            })
            delete Prism.languages.c.boolean
          },
          {}
        ],
        2: [
          function (require, module, exports) {
            Prism.languages.clike = {
              comment: [
                {
                  pattern: /(^|[^\\])\/\*[\s\S]*?(?:\*\/|$)/,
                  lookbehind: true,
                  greedy: true
                },
                {
                  pattern: /(^|[^\\:])\/\/.*/,
                  lookbehind: true,
                  greedy: true
                }
              ],
              string: {
                pattern: /(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/,
                greedy: true
              },
              'class-name': {
                pattern: /(\b(?:class|interface|extends|implements|trait|instanceof|new)\s+|\bcatch\s+\()[\w.\\]+/i,
                lookbehind: true,
                inside: { punctuation: /[.\\]/ }
              },
              keyword: /\b(?:if|else|while|do|for|return|in|instanceof|function|new|try|throw|catch|finally|null|break|continue)\b/,
              boolean: /\b(?:true|false)\b/,
              function: /\w+(?=\()/,
              number: /\b0x[\da-f]+\b|(?:\b\d+(?:\.\d*)?|\B\.\d+)(?:e[+-]?\d+)?/i,
              operator: /[<>]=?|[!=]=?=?|--?|\+\+?|&&?|\|\|?|[?*/~^%]/,
              punctuation: /[{}[\];(),.:]/
            }
          },
          {}
        ],
        3: [
          function (require, module, exports) {
            (function (global) {
              (function () {
                var _self = typeof window !== 'undefined' ? window : typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope ? self : {}
                var Prism = (function (_self) {
                  var lang = /\blang(?:uage)?-([\w-]+)\b/i
                  var uniqueId = 0
                  var _ = {
                    manual: _self.Prism && _self.Prism.manual,
                    disableWorkerMessageHandler: _self.Prism && _self.Prism.disableWorkerMessageHandler,
                    util: {
                      encode: function encode (tokens) {
                        if (tokens instanceof Token) {
                          return new Token(tokens.type, encode(tokens.content), tokens.alias)
                        } else if (Array.isArray(tokens)) {
                          return tokens.map(encode)
                        } else {
                          return tokens.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/\u00a0/g, ' ')
                        }
                      },
                      type: function (o) {
                        return Object.prototype.toString.call(o).slice(8, -1)
                      },
                      objId: function (obj) {
                        if (!obj.__id) {
                          Object.defineProperty(obj, '__id', { value: ++uniqueId })
                        }
                        return obj.__id
                      },
                      clone: function deepClone (o, visited) {
                        visited = visited || {}
                        var clone, id
                        switch (_.util.type(o)) {
                          case 'Object':
                            id = _.util.objId(o)
                            if (visited[id]) {
                              return visited[id]
                            }
                            clone = {}
                            visited[id] = clone
                            for (var key in o) {
                              if (o.hasOwnProperty(key)) {
                                clone[key] = deepClone(o[key], visited)
                              }
                            }
                            return clone
                          case 'Array':
                            id = _.util.objId(o)
                            if (visited[id]) {
                              return visited[id]
                            }
                            clone = []
                            visited[id] = clone
                            o.forEach(function (v, i) {
                              clone[i] = deepClone(v, visited)
                            })
                            return clone
                          default:
                            return o
                        }
                      },
                      getLanguage: function (element) {
                        while (element && !lang.test(element.className)) {
                          element = element.parentElement
                        }
                        if (element) {
                          return (element.className.match(lang) || [,
                            'none'
                          ])[1].toLowerCase()
                        }
                        return 'none'
                      },
                      currentScript: function () {
                        if (typeof document === 'undefined') {
                          return null
                        }
                        if ('currentScript' in document && 1 < 2) {
                          return document.currentScript
                        }
                        try {
                          throw new Error()
                        } catch (err) {
                          var src = (/at [^(\r\n]*\((.*):.+:.+\)$/i.exec(err.stack) || [])[1]
                          if (src) {
                            var scripts = document.getElementsByTagName('script')
                            for (var i in scripts) {
                              if (scripts[i].src == src) {
                                return scripts[i]
                              }
                            }
                          }
                          return null
                        }
                      },
                      isActive: function (element, className, defaultActivation) {
                        var no = 'no-' + className
                        while (element) {
                          var classList = element.classList
                          if (classList.contains(className)) {
                            return true
                          }
                          if (classList.contains(no)) {
                            return false
                          }
                          element = element.parentElement
                        }
                        return !!defaultActivation
                      }
                    },
                    languages: {
                      extend: function (id, redef) {
                        var lang = _.util.clone(_.languages[id])
                        for (var key in redef) {
                          lang[key] = redef[key]
                        }
                        return lang
                      },
                      insertBefore: function (inside, before, insert, root) {
                        root = root || _.languages
                        var grammar = root[inside]
                        var ret = {}
                        for (var token in grammar) {
                          if (grammar.hasOwnProperty(token)) {
                            if (token == before) {
                              for (var newToken in insert) {
                                if (insert.hasOwnProperty(newToken)) {
                                  ret[newToken] = insert[newToken]
                                }
                              }
                            }
                            if (!insert.hasOwnProperty(token)) {
                              ret[token] = grammar[token]
                            }
                          }
                        }
                        var old = root[inside]
                        root[inside] = ret
                        _.languages.DFS(_.languages, function (key, value) {
                          if (value === old && key != inside) {
                            this[key] = ret
                          }
                        })
                        return ret
                      },
                      DFS: function DFS (o, callback, type, visited) {
                        visited = visited || {}
                        var objId = _.util.objId
                        for (var i in o) {
                          if (o.hasOwnProperty(i)) {
                            callback.call(o, i, o[i], type || i)
                            var property = o[i]; var propertyType = _.util.type(property)
                            if (propertyType === 'Object' && !visited[objId(property)]) {
                              visited[objId(property)] = true
                              DFS(property, callback, null, visited)
                            } else if (propertyType === 'Array' && !visited[objId(property)]) {
                              visited[objId(property)] = true
                              DFS(property, callback, i, visited)
                            }
                          }
                        }
                      }
                    },
                    plugins: {},
                    highlightAll: function (async, callback) {
                      _.highlightAllUnder(document, async, callback)
                    },
                    highlightAllUnder: function (container, async, callback) {
                      var env = {
                        callback: callback,
                        container: container,
                        selector: 'code[class*="language-"], [class*="language-"] code, code[class*="lang-"], [class*="lang-"] code'
                      }
                      _.hooks.run('before-highlightall', env)
                      env.elements = Array.prototype.slice.apply(env.container.querySelectorAll(env.selector))
                      _.hooks.run('before-all-elements-highlight', env)
                      for (var i = 0, element; element = env.elements[i++];) {
                        _.highlightElement(element, async === true, env.callback)
                      }
                    },
                    highlightElement: function (element, async, callback) {
                      var language = _.util.getLanguage(element)
                      var grammar = _.languages[language]
                      element.className = element.className.replace(lang, '').replace(/\s+/g, ' ') + ' language-' + language
                      var parent = element.parentElement
                      if (parent && parent.nodeName.toLowerCase() === 'pre') {
                        parent.className = parent.className.replace(lang, '').replace(/\s+/g, ' ') + ' language-' + language
                      }
                      var code = element.textContent
                      var env = {
                        element: element,
                        language: language,
                        grammar: grammar,
                        code: code
                      }
                      function insertHighlightedCode (highlightedCode) {
                        env.highlightedCode = highlightedCode
                        _.hooks.run('before-insert', env)
                        env.element.innerHTML = env.highlightedCode
                        _.hooks.run('after-highlight', env)
                        _.hooks.run('complete', env)
                        callback && callback.call(env.element)
                      }
                      _.hooks.run('before-sanity-check', env)
                      if (!env.code) {
                        _.hooks.run('complete', env)
                        callback && callback.call(env.element)
                        return
                      }
                      _.hooks.run('before-highlight', env)
                      if (!env.grammar) {
                        insertHighlightedCode(_.util.encode(env.code))
                        return
                      }
                      if (async && _self.Worker) {
                        var worker = new Worker(_.filename)
                        worker.onmessage = function (evt) {
                          insertHighlightedCode(evt.data)
                        }
                        worker.postMessage(JSON.stringify({
                          language: env.language,
                          code: env.code,
                          immediateClose: true
                        }))
                      } else {
                        insertHighlightedCode(_.highlight(env.code, env.grammar, env.language))
                      }
                    },
                    highlight: function (text, grammar, language) {
                      var env = {
                        code: text,
                        grammar: grammar,
                        language: language
                      }
                      _.hooks.run('before-tokenize', env)
                      env.tokens = _.tokenize(env.code, env.grammar)
                      _.hooks.run('after-tokenize', env)
                      return Token.stringify(_.util.encode(env.tokens), env.language)
                    },
                    tokenize: function (text, grammar) {
                      var rest = grammar.rest
                      if (rest) {
                        for (var token in rest) {
                          grammar[token] = rest[token]
                        }
                        delete grammar.rest
                      }
                      var tokenList = new LinkedList()
                      addAfter(tokenList, tokenList.head, text)
                      matchGrammar(text, tokenList, grammar, tokenList.head, 0)
                      return toArray(tokenList)
                    },
                    hooks: {
                      all: {},
                      add: function (name, callback) {
                        var hooks = _.hooks.all
                        hooks[name] = hooks[name] || []
                        hooks[name].push(callback)
                      },
                      run: function (name, env) {
                        var callbacks = _.hooks.all[name]
                        if (!callbacks || !callbacks.length) {
                          return
                        }
                        for (var i = 0, callback; callback = callbacks[i++];) {
                          callback(env)
                        }
                      }
                    },
                    Token: Token
                  }
                  _self.Prism = _
                  function Token (type, content, alias, matchedStr) {
                    this.type = type
                    this.content = content
                    this.alias = alias
                    this.length = (matchedStr || '').length | 0
                  }
                  Token.stringify = function stringify (o, language) {
                    if (typeof o === 'string') {
                      return o
                    }
                    if (Array.isArray(o)) {
                      var s = ''
                      o.forEach(function (e) {
                        s += stringify(e, language)
                      })
                      return s
                    }
                    var env = {
                      type: o.type,
                      content: stringify(o.content, language),
                      tag: 'span',
                      classes: [
                        'token',
                        o.type
                      ],
                      attributes: {},
                      language: language
                    }
                    var aliases = o.alias
                    if (aliases) {
                      if (Array.isArray(aliases)) {
                        Array.prototype.push.apply(env.classes, aliases)
                      } else {
                        env.classes.push(aliases)
                      }
                    }
                    _.hooks.run('wrap', env)
                    var attributes = ''
                    for (var name in env.attributes) {
                      attributes += ' ' + name + '="' + (env.attributes[name] || '').replace(/"/g, '&quot;') + '"'
                    }
                    return '<' + env.tag + ' class="' + env.classes.join(' ') + '"' + attributes + '>' + env.content + '</' + env.tag + '>'
                  }
                  function matchPattern (pattern, pos, text, lookbehind) {
                    pattern.lastIndex = pos
                    var match = pattern.exec(text)
                    if (match && lookbehind && match[1]) {
                      var lookbehindLength = match[1].length
                      match.index += lookbehindLength
                      match[0] = match[0].slice(lookbehindLength)
                    }
                    return match
                  }
                  function matchGrammar (text, tokenList, grammar, startNode, startPos, rematch) {
                    for (var token in grammar) {
                      if (!grammar.hasOwnProperty(token) || !grammar[token]) {
                        continue
                      }
                      var patterns = grammar[token]
                      patterns = Array.isArray(patterns) ? patterns : [patterns]
                      for (var j = 0; j < patterns.length; ++j) {
                        if (rematch && rematch.cause == token + ',' + j) {
                          return
                        }
                        var patternObj = patterns[j]; var inside = patternObj.inside; var lookbehind = !!patternObj.lookbehind; var greedy = !!patternObj.greedy; var alias = patternObj.alias
                        if (greedy && !patternObj.pattern.global) {
                          var flags = patternObj.pattern.toString().match(/[imsuy]*$/)[0]
                          patternObj.pattern = RegExp(patternObj.pattern.source, flags + 'g')
                        }
                        var pattern = patternObj.pattern || patternObj
                        for (var currentNode = startNode.next, pos = startPos; currentNode !== tokenList.tail; pos += currentNode.value.length, currentNode = currentNode.next) {
                          if (rematch && pos >= rematch.reach) {
                            break
                          }
                          var str = currentNode.value
                          if (tokenList.length > text.length) {
                            return
                          }
                          if (str instanceof Token) {
                            continue
                          }
                          var removeCount = 1
                          var match
                          if (greedy) {
                            match = matchPattern(pattern, pos, text, lookbehind)
                            if (!match) {
                              break
                            }
                            var from = match.index
                            var to = match.index + match[0].length
                            var p = pos
                            p += currentNode.value.length
                            while (from >= p) {
                              currentNode = currentNode.next
                              p += currentNode.value.length
                            }
                            p -= currentNode.value.length
                            pos = p
                            if (currentNode.value instanceof Token) {
                              continue
                            }
                            for (var k = currentNode; k !== tokenList.tail && (p < to || typeof k.value === 'string'); k = k.next) {
                              removeCount++
                              p += k.value.length
                            }
                            removeCount--
                            str = text.slice(pos, p)
                            match.index -= pos
                          } else {
                            match = matchPattern(pattern, 0, str, lookbehind)
                            if (!match) {
                              continue
                            }
                          }
                          var from = match.index; var matchStr = match[0]; var before = str.slice(0, from); var after = str.slice(from + matchStr.length)
                          var reach = pos + str.length
                          if (rematch && reach > rematch.reach) {
                            rematch.reach = reach
                          }
                          var removeFrom = currentNode.prev
                          if (before) {
                            removeFrom = addAfter(tokenList, removeFrom, before)
                            pos += before.length
                          }
                          removeRange(tokenList, removeFrom, removeCount)
                          var wrapped = new Token(token, inside ? _.tokenize(matchStr, inside) : matchStr, alias, matchStr)
                          currentNode = addAfter(tokenList, removeFrom, wrapped)
                          if (after) {
                            addAfter(tokenList, currentNode, after)
                          }
                          if (removeCount > 1) {
                            matchGrammar(text, tokenList, grammar, currentNode.prev, pos, {
                              cause: token + ',' + j,
                              reach: reach
                            })
                          }
                        }
                      }
                    }
                  }
                  function LinkedList () {
                    var head = {
                      value: null,
                      prev: null,
                      next: null
                    }
                    var tail = {
                      value: null,
                      prev: head,
                      next: null
                    }
                    head.next = tail
                    this.head = head
                    this.tail = tail
                    this.length = 0
                  }
                  function addAfter (list, node, value) {
                    var next = node.next
                    var newNode = {
                      value: value,
                      prev: node,
                      next: next
                    }
                    node.next = newNode
                    next.prev = newNode
                    list.length++
                    return newNode
                  }
                  function removeRange (list, node, count) {
                    var next = node.next
                    for (var i = 0; i < count && next !== list.tail; i++) {
                      next = next.next
                    }
                    node.next = next
                    next.prev = node
                    list.length -= i
                  }
                  function toArray (list) {
                    var array = []
                    var node = list.head.next
                    while (node !== list.tail) {
                      array.push(node.value)
                      node = node.next
                    }
                    return array
                  }
                  if (!_self.document) {
                    if (!_self.addEventListener) {
                      return _
                    }
                    if (!_.disableWorkerMessageHandler) {
                      _self.addEventListener('message', function (evt) {
                        var message = JSON.parse(evt.data); var lang = message.language; var code = message.code; var immediateClose = message.immediateClose
                        _self.postMessage(_.highlight(code, _.languages[lang], lang))
                        if (immediateClose) {
                          _self.close()
                        }
                      }, false)
                    }
                    return _
                  }
                  var script = _.util.currentScript()
                  if (script) {
                    _.filename = script.src
                    if (script.hasAttribute('data-manual')) {
                      _.manual = true
                    }
                  }
                  function highlightAutomaticallyCallback () {
                    if (!_.manual) {
                      _.highlightAll()
                    }
                  }
                  if (!_.manual) {
                    var readyState = document.readyState
                    if (readyState === 'loading' || readyState === 'interactive' && script && script.defer) {
                      document.addEventListener('DOMContentLoaded', highlightAutomaticallyCallback)
                    } else {
                      if (window.requestAnimationFrame) {
                        window.requestAnimationFrame(highlightAutomaticallyCallback)
                      } else {
                        window.setTimeout(highlightAutomaticallyCallback, 16)
                      }
                    }
                  }
                  return _
                }(_self))
                if (typeof module !== 'undefined' && module.exports) {
                  module.exports = Prism
                }
                if (typeof global !== 'undefined') {
                  global.Prism = Prism
                }
              }.call(this))
            }.call(this, typeof global$2 !== 'undefined' ? global$2 : typeof self !== 'undefined' ? self : typeof window !== 'undefined' ? window : {}))
          },
          {}
        ],
        4: [
          function (require, module, exports) {
            (function (Prism) {
              var keyword = /\b(?:alignas|alignof|asm|auto|bool|break|case|catch|char|char8_t|char16_t|char32_t|class|compl|concept|const|consteval|constexpr|constinit|const_cast|continue|co_await|co_return|co_yield|decltype|default|delete|do|double|dynamic_cast|else|enum|explicit|export|extern|float|for|friend|goto|if|inline|int|int8_t|int16_t|int32_t|int64_t|uint8_t|uint16_t|uint32_t|uint64_t|long|mutable|namespace|new|noexcept|nullptr|operator|private|protected|public|register|reinterpret_cast|requires|return|short|signed|sizeof|static|static_assert|static_cast|struct|switch|template|this|thread_local|throw|try|typedef|typeid|typename|union|unsigned|using|virtual|void|volatile|wchar_t|while)\b/
              Prism.languages.cpp = Prism.languages.extend('c', {
                'class-name': [
                  {
                    pattern: RegExp(/(\b(?:class|concept|enum|struct|typename)\s+)(?!<keyword>)\w+/.source.replace(/<keyword>/g, function () {
                      return keyword.source
                    })),
                    lookbehind: true
                  },
                  /\b[A-Z]\w*(?=\s*::\s*\w+\s*\()/,
                  /\b[A-Z_]\w*(?=\s*::\s*~\w+\s*\()/i,
                  /\w+(?=\s*<(?:[^<>]|<(?:[^<>]|<[^<>]*>)*>)*>\s*::\s*\w+\s*\()/
                ],
                keyword: keyword,
                number: {
                  pattern: /(?:\b0b[01']+|\b0x(?:[\da-f']+(?:\.[\da-f']*)?|\.[\da-f']+)(?:p[+-]?[\d']+)?|(?:\b[\d']+(?:\.[\d']*)?|\B\.[\d']+)(?:e[+-]?[\d']+)?)[ful]{0,4}/i,
                  greedy: true
                },
                operator: />>=?|<<=?|->|([-+&|:])\1|[?:~]|<=>|[-+*/%&|^!=<>]=?|\b(?:and|and_eq|bitand|bitor|not|not_eq|or|or_eq|xor|xor_eq)\b/,
                boolean: /\b(?:true|false)\b/
              })
              Prism.languages.insertBefore('cpp', 'string', {
                'raw-string': {
                  pattern: /R"([^()\\ ]{0,16})\([\s\S]*?\)\1"/,
                  alias: 'string',
                  greedy: true
                }
              })
              Prism.languages.insertBefore('cpp', 'class-name', {
                'base-clause': {
                  pattern: /(\b(?:class|struct)\s+\w+\s*:\s*)[^;{}"'\s]+(?:\s+[^;{}"'\s]+)*(?=\s*[;{])/,
                  lookbehind: true,
                  greedy: true,
                  inside: Prism.languages.extend('cpp', {})
                }
              })
              Prism.languages.insertBefore('inside', 'operator', { 'class-name': /\b[a-z_]\w*\b(?!\s*::)/i }, Prism.languages.cpp['base-clause'])
            }(Prism))
          },
          {}
        ],
        5: [
          function (require, module, exports) {
            (function (Prism) {
              function replace (pattern, replacements) {
                return pattern.replace(/<<(\d+)>>/g, function (m, index) {
                  return '(?:' + replacements[+index] + ')'
                })
              }
              function re (pattern, replacements, flags) {
                return RegExp(replace(pattern, replacements), flags || '')
              }
              function nested (pattern, depthLog2) {
                for (var i = 0; i < depthLog2; i++) {
                  pattern = pattern.replace(/<<self>>/g, function () {
                    return '(?:' + pattern + ')'
                  })
                }
                return pattern.replace(/<<self>>/g, '[^\\s\\S]')
              }
              var keywordKinds = {
                type: 'bool byte char decimal double dynamic float int long object sbyte short string uint ulong ushort var void',
                typeDeclaration: 'class enum interface struct',
                contextual: 'add alias and ascending async await by descending from get global group into join let nameof not notnull on or orderby partial remove select set unmanaged value when where',
                other: 'abstract as base break case catch checked const continue default delegate do else event explicit extern finally fixed for foreach goto if implicit in internal is lock namespace new null operator out override params private protected public readonly ref return sealed sizeof stackalloc static switch this throw try typeof unchecked unsafe using virtual volatile while yield'
              }
              function keywordsToPattern (words) {
                return '\\b(?:' + words.trim().replace(/ /g, '|') + ')\\b'
              }
              var typeDeclarationKeywords = keywordsToPattern(keywordKinds.typeDeclaration)
              var keywords = RegExp(keywordsToPattern(keywordKinds.type + ' ' + keywordKinds.typeDeclaration + ' ' + keywordKinds.contextual + ' ' + keywordKinds.other))
              var nonTypeKeywords = keywordsToPattern(keywordKinds.typeDeclaration + ' ' + keywordKinds.contextual + ' ' + keywordKinds.other)
              var nonContextualKeywords = keywordsToPattern(keywordKinds.type + ' ' + keywordKinds.typeDeclaration + ' ' + keywordKinds.other)
              var generic = nested(/<(?:[^<>;=+\-*/%&|^]|<<self>>)*>/.source, 2)
              var nestedRound = nested(/\((?:[^()]|<<self>>)*\)/.source, 2)
              var name = /@?\b[A-Za-z_]\w*\b/.source
              var genericName = replace(/<<0>>(?:\s*<<1>>)?/.source, [
                name,
                generic
              ])
              var identifier = replace(/(?!<<0>>)<<1>>(?:\s*\.\s*<<1>>)*/.source, [
                nonTypeKeywords,
                genericName
              ])
              var array = /\[\s*(?:,\s*)*\]/.source
              var typeExpressionWithoutTuple = replace(/<<0>>(?:\s*(?:\?\s*)?<<1>>)*(?:\s*\?)?/.source, [
                identifier,
                array
              ])
              var tupleElement = replace(/[^,()<>[\];=+\-*/%&|^]|<<0>>|<<1>>|<<2>>/.source, [
                generic,
                nestedRound,
                array
              ])
              var tuple = replace(/\(<<0>>+(?:,<<0>>+)+\)/.source, [tupleElement])
              var typeExpression = replace(/(?:<<0>>|<<1>>)(?:\s*(?:\?\s*)?<<2>>)*(?:\s*\?)?/.source, [
                tuple,
                identifier,
                array
              ])
              var typeInside = {
                keyword: keywords,
                punctuation: /[<>()?,.:[\]]/
              }
              var character = /'(?:[^\r\n'\\]|\\.|\\[Uux][\da-fA-F]{1,8})'/.source
              var regularString = /"(?:\\.|[^\\"\r\n])*"/.source
              var verbatimString = /@"(?:""|\\[\s\S]|[^\\"])*"(?!")/.source
              Prism.languages.csharp = Prism.languages.extend('clike', {
                string: [
                  {
                    pattern: re(/(^|[^$\\])<<0>>/.source, [verbatimString]),
                    lookbehind: true,
                    greedy: true
                  },
                  {
                    pattern: re(/(^|[^@$\\])<<0>>/.source, [regularString]),
                    lookbehind: true,
                    greedy: true
                  },
                  {
                    pattern: RegExp(character),
                    greedy: true,
                    alias: 'character'
                  }
                ],
                'class-name': [
                  {
                    pattern: re(/(\busing\s+static\s+)<<0>>(?=\s*;)/.source, [identifier]),
                    lookbehind: true,
                    inside: typeInside
                  },
                  {
                    pattern: re(/(\busing\s+<<0>>\s*=\s*)<<1>>(?=\s*;)/.source, [
                      name,
                      typeExpression
                    ]),
                    lookbehind: true,
                    inside: typeInside
                  },
                  {
                    pattern: re(/(\busing\s+)<<0>>(?=\s*=)/.source, [name]),
                    lookbehind: true
                  },
                  {
                    pattern: re(/(\b<<0>>\s+)<<1>>/.source, [
                      typeDeclarationKeywords,
                      genericName
                    ]),
                    lookbehind: true,
                    inside: typeInside
                  },
                  {
                    pattern: re(/(\bcatch\s*\(\s*)<<0>>/.source, [identifier]),
                    lookbehind: true,
                    inside: typeInside
                  },
                  {
                    pattern: re(/(\bwhere\s+)<<0>>/.source, [name]),
                    lookbehind: true
                  },
                  {
                    pattern: re(/(\b(?:is(?:\s+not)?|as)\s+)<<0>>/.source, [typeExpressionWithoutTuple]),
                    lookbehind: true,
                    inside: typeInside
                  },
                  {
                    pattern: re(/\b<<0>>(?=\s+(?!<<1>>)<<2>>(?:\s*[=,;:{)\]]|\s+(?:in|when)\b))/.source, [
                      typeExpression,
                      nonContextualKeywords,
                      name
                    ]),
                    inside: typeInside
                  }
                ],
                keyword: keywords,
                number: /(?:\b0(?:x[\da-f_]*[\da-f]|b[01_]*[01])|(?:\B\.\d+(?:_+\d+)*|\b\d+(?:_+\d+)*(?:\.\d+(?:_+\d+)*)?)(?:e[-+]?\d+(?:_+\d+)*)?)(?:ul|lu|[dflmu])?\b/i,
                operator: />>=?|<<=?|[-=]>|([-+&|])\1|~|\?\?=?|[-+*/%&|^!=<>]=?/,
                punctuation: /\?\.?|::|[{}[\];(),.:]/
              })
              Prism.languages.insertBefore('csharp', 'number', {
                range: {
                  pattern: /\.\./,
                  alias: 'operator'
                }
              })
              Prism.languages.insertBefore('csharp', 'punctuation', {
                'named-parameter': {
                  pattern: re(/([(,]\s*)<<0>>(?=\s*:)/.source, [name]),
                  lookbehind: true,
                  alias: 'punctuation'
                }
              })
              Prism.languages.insertBefore('csharp', 'class-name', {
                namespace: {
                  pattern: re(/(\b(?:namespace|using)\s+)<<0>>(?:\s*\.\s*<<0>>)*(?=\s*[;{])/.source, [name]),
                  lookbehind: true,
                  inside: { punctuation: /\./ }
                },
                'type-expression': {
                  pattern: re(/(\b(?:default|typeof|sizeof)\s*\(\s*(?!\s))(?:[^()\s]|\s(?!\s)|<<0>>)*(?=\s*\))/.source, [nestedRound]),
                  lookbehind: true,
                  alias: 'class-name',
                  inside: typeInside
                },
                'return-type': {
                  pattern: re(/<<0>>(?=\s+(?:<<1>>\s*(?:=>|[({]|\.\s*this\s*\[)|this\s*\[))/.source, [
                    typeExpression,
                    identifier
                  ]),
                  inside: typeInside,
                  alias: 'class-name'
                },
                'constructor-invocation': {
                  pattern: re(/(\bnew\s+)<<0>>(?=\s*[[({])/.source, [typeExpression]),
                  lookbehind: true,
                  inside: typeInside,
                  alias: 'class-name'
                },
                'generic-method': {
                  pattern: re(/<<0>>\s*<<1>>(?=\s*\()/.source, [
                    name,
                    generic
                  ]),
                  inside: {
                    function: re(/^<<0>>/.source, [name]),
                    generic: {
                      pattern: RegExp(generic),
                      alias: 'class-name',
                      inside: typeInside
                    }
                  }
                },
                'type-list': {
                  pattern: re(/\b((?:<<0>>\s+<<1>>|where\s+<<2>>)\s*:\s*)(?:<<3>>|<<4>>)(?:\s*,\s*(?:<<3>>|<<4>>))*(?=\s*(?:where|[{;]|=>|$))/.source, [
                    typeDeclarationKeywords,
                    genericName,
                    name,
                    typeExpression,
                    keywords.source
                  ]),
                  lookbehind: true,
                  inside: {
                    keyword: keywords,
                    'class-name': {
                      pattern: RegExp(typeExpression),
                      greedy: true,
                      inside: typeInside
                    },
                    punctuation: /,/
                  }
                },
                preprocessor: {
                  pattern: /(^\s*)#.*/m,
                  lookbehind: true,
                  alias: 'property',
                  inside: {
                    directive: {
                      pattern: /(\s*#)\b(?:define|elif|else|endif|endregion|error|if|line|pragma|region|undef|warning)\b/,
                      lookbehind: true,
                      alias: 'keyword'
                    }
                  }
                }
              })
              var regularStringOrCharacter = regularString + '|' + character
              var regularStringCharacterOrComment = replace(/\/(?![*/])|\/\/[^\r\n]*[\r\n]|\/\*(?:[^*]|\*(?!\/))*\*\/|<<0>>/.source, [regularStringOrCharacter])
              var roundExpression = nested(replace(/[^"'/()]|<<0>>|\(<<self>>*\)/.source, [regularStringCharacterOrComment]), 2)
              var attrTarget = /\b(?:assembly|event|field|method|module|param|property|return|type)\b/.source
              var attr = replace(/<<0>>(?:\s*\(<<1>>*\))?/.source, [
                identifier,
                roundExpression
              ])
              Prism.languages.insertBefore('csharp', 'class-name', {
                attribute: {
                  pattern: re(/((?:^|[^\s\w>)?])\s*\[\s*)(?:<<0>>\s*:\s*)?<<1>>(?:\s*,\s*<<1>>)*(?=\s*\])/.source, [
                    attrTarget,
                    attr
                  ]),
                  lookbehind: true,
                  greedy: true,
                  inside: {
                    target: {
                      pattern: re(/^<<0>>(?=\s*:)/.source, [attrTarget]),
                      alias: 'keyword'
                    },
                    'attribute-arguments': {
                      pattern: re(/\(<<0>>*\)/.source, [roundExpression]),
                      inside: Prism.languages.csharp
                    },
                    'class-name': {
                      pattern: RegExp(identifier),
                      inside: { punctuation: /\./ }
                    },
                    punctuation: /[:,]/
                  }
                }
              })
              var formatString = /:[^}\r\n]+/.source
              var mInterpolationRound = nested(replace(/[^"'/()]|<<0>>|\(<<self>>*\)/.source, [regularStringCharacterOrComment]), 2)
              var mInterpolation = replace(/\{(?!\{)(?:(?![}:])<<0>>)*<<1>>?\}/.source, [
                mInterpolationRound,
                formatString
              ])
              var sInterpolationRound = nested(replace(/[^"'/()]|\/(?!\*)|\/\*(?:[^*]|\*(?!\/))*\*\/|<<0>>|\(<<self>>*\)/.source, [regularStringOrCharacter]), 2)
              var sInterpolation = replace(/\{(?!\{)(?:(?![}:])<<0>>)*<<1>>?\}/.source, [
                sInterpolationRound,
                formatString
              ])
              function createInterpolationInside (interpolation, interpolationRound) {
                return {
                  interpolation: {
                    pattern: re(/((?:^|[^{])(?:\{\{)*)<<0>>/.source, [interpolation]),
                    lookbehind: true,
                    inside: {
                      'format-string': {
                        pattern: re(/(^\{(?:(?![}:])<<0>>)*)<<1>>(?=\}$)/.source, [
                          interpolationRound,
                          formatString
                        ]),
                        lookbehind: true,
                        inside: { punctuation: /^:/ }
                      },
                      punctuation: /^\{|\}$/,
                      expression: {
                        pattern: /[\s\S]+/,
                        alias: 'language-csharp',
                        inside: Prism.languages.csharp
                      }
                    }
                  },
                  string: /[\s\S]+/
                }
              }
              Prism.languages.insertBefore('csharp', 'string', {
                'interpolation-string': [
                  {
                    pattern: re(/(^|[^\\])(?:\$@|@\$)"(?:""|\\[\s\S]|\{\{|<<0>>|[^\\{"])*"/.source, [mInterpolation]),
                    lookbehind: true,
                    greedy: true,
                    inside: createInterpolationInside(mInterpolation, mInterpolationRound)
                  },
                  {
                    pattern: re(/(^|[^@\\])\$"(?:\\.|\{\{|<<0>>|[^\\"{])*"/.source, [sInterpolation]),
                    lookbehind: true,
                    greedy: true,
                    inside: createInterpolationInside(sInterpolation, sInterpolationRound)
                  }
                ]
              })
            }(Prism))
            Prism.languages.dotnet = Prism.languages.cs = Prism.languages.csharp
          },
          {}
        ],
        6: [
          function (require, module, exports) {
            (function (Prism) {
              var string = /("|')(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/
              Prism.languages.css = {
                comment: /\/\*[\s\S]*?\*\//,
                atrule: {
                  pattern: /@[\w-](?:[^;{\s]|\s+(?![\s{]))*(?:;|(?=\s*\{))/,
                  inside: {
                    rule: /^@[\w-]+/,
                    'selector-function-argument': {
                      pattern: /(\bselector\s*\(\s*(?![\s)]))(?:[^()\s]|\s+(?![\s)])|\((?:[^()]|\([^()]*\))*\))+(?=\s*\))/,
                      lookbehind: true,
                      alias: 'selector'
                    },
                    keyword: {
                      pattern: /(^|[^\w-])(?:and|not|only|or)(?![\w-])/,
                      lookbehind: true
                    }
                  }
                },
                url: {
                  pattern: RegExp('\\burl\\((?:' + string.source + '|' + /(?:[^\\\r\n()"']|\\[\s\S])*/.source + ')\\)', 'i'),
                  greedy: true,
                  inside: {
                    function: /^url/i,
                    punctuation: /^\(|\)$/,
                    string: {
                      pattern: RegExp('^' + string.source + '$'),
                      alias: 'url'
                    }
                  }
                },
                selector: RegExp('[^{}\\s](?:[^{};"\'\\s]|\\s+(?![\\s{])|' + string.source + ')*(?=\\s*\\{)'),
                string: {
                  pattern: string,
                  greedy: true
                },
                property: /(?!\s)[-_a-z\xA0-\uFFFF](?:(?!\s)[-\w\xA0-\uFFFF])*(?=\s*:)/i,
                important: /!important\b/i,
                function: /[-a-z0-9]+(?=\()/i,
                punctuation: /[(){};:,]/
              }
              Prism.languages.css.atrule.inside.rest = Prism.languages.css
              var markup = Prism.languages.markup
              if (markup) {
                markup.tag.addInlined('style', 'css')
                Prism.languages.insertBefore('inside', 'attr-value', {
                  'style-attr': {
                    pattern: /(^|["'\s])style\s*=\s*(?:"[^"]*"|'[^']*')/i,
                    lookbehind: true,
                    inside: {
                      'attr-value': {
                        pattern: /=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+)/,
                        inside: {
                          style: {
                            pattern: /(["'])[\s\S]+(?=["']$)/,
                            lookbehind: true,
                            alias: 'language-css',
                            inside: Prism.languages.css
                          },
                          punctuation: [
                            {
                              pattern: /^=/,
                              alias: 'attr-equals'
                            },
                            /"|'/
                          ]
                        }
                      },
                      'attr-name': /^style/i
                    }
                  }
                }, markup.tag)
              }
            }(Prism))
          },
          {}
        ],
        7: [
          function (require, module, exports) {
            (function (Prism) {
              var keywords = /\b(?:abstract|assert|boolean|break|byte|case|catch|char|class|const|continue|default|do|double|else|enum|exports|extends|final|finally|float|for|goto|if|implements|import|instanceof|int|interface|long|module|native|new|non-sealed|null|open|opens|package|permits|private|protected|provides|public|record|requires|return|sealed|short|static|strictfp|super|switch|synchronized|this|throw|throws|to|transient|transitive|try|uses|var|void|volatile|while|with|yield)\b/
              var classNamePrefix = /(^|[^\w.])(?:[a-z]\w*\s*\.\s*)*(?:[A-Z]\w*\s*\.\s*)*/.source
              var className = {
                pattern: RegExp(classNamePrefix + /[A-Z](?:[\d_A-Z]*[a-z]\w*)?\b/.source),
                lookbehind: true,
                inside: {
                  namespace: {
                    pattern: /^[a-z]\w*(?:\s*\.\s*[a-z]\w*)*(?:\s*\.)?/,
                    inside: { punctuation: /\./ }
                  },
                  punctuation: /\./
                }
              }
              Prism.languages.java = Prism.languages.extend('clike', {
                'class-name': [
                  className,
                  {
                    pattern: RegExp(classNamePrefix + /[A-Z]\w*(?=\s+\w+\s*[;,=())])/.source),
                    lookbehind: true,
                    inside: className.inside
                  }
                ],
                keyword: keywords,
                function: [
                  Prism.languages.clike.function,
                  {
                    pattern: /(\:\:\s*)[a-z_]\w*/,
                    lookbehind: true
                  }
                ],
                number: /\b0b[01][01_]*L?\b|\b0x(?:\.[\da-f_p+-]+|[\da-f_]+(?:\.[\da-f_p+-]+)?)\b|(?:\b\d[\d_]*(?:\.[\d_]*)?|\B\.\d[\d_]*)(?:e[+-]?\d[\d_]*)?[dfl]?/i,
                operator: {
                  pattern: /(^|[^.])(?:<<=?|>>>?=?|->|--|\+\+|&&|\|\||::|[?:~]|[-+*/%&|^!=<>]=?)/m,
                  lookbehind: true
                }
              })
              Prism.languages.insertBefore('java', 'string', {
                'triple-quoted-string': {
                  pattern: /"""[ \t]*[\r\n](?:(?:"|"")?(?:\\.|[^"\\]))*"""/,
                  greedy: true,
                  alias: 'string'
                }
              })
              Prism.languages.insertBefore('java', 'class-name', {
                annotation: {
                  pattern: /(^|[^.])@\w+(?:\s*\.\s*\w+)*/,
                  lookbehind: true,
                  alias: 'punctuation'
                },
                generics: {
                  pattern: /<(?:[\w\s,.&?]|<(?:[\w\s,.&?]|<(?:[\w\s,.&?]|<[\w\s,.&?]*>)*>)*>)*>/,
                  inside: {
                    'class-name': className,
                    keyword: keywords,
                    punctuation: /[<>(),.:]/,
                    operator: /[?&|]/
                  }
                },
                namespace: {
                  pattern: RegExp(/(\b(?:exports|import(?:\s+static)?|module|open|opens|package|provides|requires|to|transitive|uses|with)\s+)(?!<keyword>)[a-z]\w*(?:\.[a-z]\w*)*\.?/.source.replace(/<keyword>/g, function () {
                    return keywords.source
                  })),
                  lookbehind: true,
                  inside: { punctuation: /\./ }
                }
              })
            }(Prism))
          },
          {}
        ],
        8: [
          function (require, module, exports) {
            Prism.languages.javascript = Prism.languages.extend('clike', {
              'class-name': [
                Prism.languages.clike['class-name'],
                {
                  pattern: /(^|[^$\w\xA0-\uFFFF])(?!\s)[_$A-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\.(?:prototype|constructor))/,
                  lookbehind: true
                }
              ],
              keyword: [
                {
                  pattern: /((?:^|})\s*)(?:catch|finally)\b/,
                  lookbehind: true
                },
                {
                  pattern: /(^|[^.]|\.\.\.\s*)\b(?:as|async(?=\s*(?:function\b|\(|[$\w\xA0-\uFFFF]|$))|await|break|case|class|const|continue|debugger|default|delete|do|else|enum|export|extends|for|from|function|(?:get|set)(?=\s*[\[$\w\xA0-\uFFFF])|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)\b/,
                  lookbehind: true
                }
              ],
              function: /#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*(?:\.\s*(?:apply|bind|call)\s*)?\()/,
              number: /\b(?:(?:0[xX](?:[\dA-Fa-f](?:_[\dA-Fa-f])?)+|0[bB](?:[01](?:_[01])?)+|0[oO](?:[0-7](?:_[0-7])?)+)n?|(?:\d(?:_\d)?)+n|NaN|Infinity)\b|(?:\b(?:\d(?:_\d)?)+\.?(?:\d(?:_\d)?)*|\B\.(?:\d(?:_\d)?)+)(?:[Ee][+-]?(?:\d(?:_\d)?)+)?/,
              operator: /--|\+\+|\*\*=?|=>|&&=?|\|\|=?|[!=]==|<<=?|>>>?=?|[-+*/%&|^!=<>]=?|\.{3}|\?\?=?|\?\.?|[~:]/
            })
            Prism.languages.javascript['class-name'][0].pattern = /(\b(?:class|interface|extends|implements|instanceof|new)\s+)[\w.\\]+/
            Prism.languages.insertBefore('javascript', 'keyword', {
              regex: {
                pattern: /((?:^|[^$\w\xA0-\uFFFF."'\])\s]|\b(?:return|yield))\s*)\/(?:\[(?:[^\]\\\r\n]|\\.)*]|\\.|[^/\\\[\r\n])+\/[gimyus]{0,6}(?=(?:\s|\/\*(?:[^*]|\*(?!\/))*\*\/)*(?:$|[\r\n,.;:})\]]|\/\/))/,
                lookbehind: true,
                greedy: true,
                inside: {
                  'regex-source': {
                    pattern: /^(\/)[\s\S]+(?=\/[a-z]*$)/,
                    lookbehind: true,
                    alias: 'language-regex',
                    inside: Prism.languages.regex
                  },
                  'regex-flags': /[a-z]+$/,
                  'regex-delimiter': /^\/|\/$/
                }
              },
              'function-variable': {
                pattern: /#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*[=:]\s*(?:async\s*)?(?:\bfunction\b|(?:\((?:[^()]|\([^()]*\))*\)|(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)\s*=>))/,
                alias: 'function'
              },
              parameter: [
                {
                  pattern: /(function(?:\s+(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)?\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\))/,
                  lookbehind: true,
                  inside: Prism.languages.javascript
                },
                {
                  pattern: /(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*=>)/i,
                  inside: Prism.languages.javascript
                },
                {
                  pattern: /(\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*=>)/,
                  lookbehind: true,
                  inside: Prism.languages.javascript
                },
                {
                  pattern: /((?:\b|\s|^)(?!(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)(?![$\w\xA0-\uFFFF]))(?:(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*\s*)\(\s*|\]\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*\{)/,
                  lookbehind: true,
                  inside: Prism.languages.javascript
                }
              ],
              constant: /\b[A-Z](?:[A-Z_]|\dx?)*\b/
            })
            Prism.languages.insertBefore('javascript', 'string', {
              'template-string': {
                pattern: /`(?:\\[\s\S]|\${(?:[^{}]|{(?:[^{}]|{[^}]*})*})+}|(?!\${)[^\\`])*`/,
                greedy: true,
                inside: {
                  'template-punctuation': {
                    pattern: /^`|`$/,
                    alias: 'string'
                  },
                  interpolation: {
                    pattern: /((?:^|[^\\])(?:\\{2})*)\${(?:[^{}]|{(?:[^{}]|{[^}]*})*})+}/,
                    lookbehind: true,
                    inside: {
                      'interpolation-punctuation': {
                        pattern: /^\${|}$/,
                        alias: 'punctuation'
                      },
                      rest: Prism.languages.javascript
                    }
                  },
                  string: /[\s\S]+/
                }
              }
            })
            if (Prism.languages.markup) {
              Prism.languages.markup.tag.addInlined('script', 'javascript')
            }
            Prism.languages.js = Prism.languages.javascript
          },
          {}
        ],
        9: [
          function (require, module, exports) {
            (function (Prism) {
              function getPlaceholder (language, index) {
                return '___' + language.toUpperCase() + index + '___'
              }
              Object.defineProperties(Prism.languages['markup-templating'] = {}, {
                buildPlaceholders: {
                  value: function (env, language, placeholderPattern, replaceFilter) {
                    if (env.language !== language) {
                      return
                    }
                    var tokenStack = env.tokenStack = []
                    env.code = env.code.replace(placeholderPattern, function (match) {
                      if (typeof replaceFilter === 'function' && !replaceFilter(match)) {
                        return match
                      }
                      var i = tokenStack.length
                      var placeholder
                      while (env.code.indexOf(placeholder = getPlaceholder(language, i)) !== -1) { ++i }
                      tokenStack[i] = match
                      return placeholder
                    })
                    env.grammar = Prism.languages.markup
                  }
                },
                tokenizePlaceholders: {
                  value: function (env, language) {
                    if (env.language !== language || !env.tokenStack) {
                      return
                    }
                    env.grammar = Prism.languages[language]
                    var j = 0
                    var keys = Object.keys(env.tokenStack)
                    function walkTokens (tokens) {
                      for (var i = 0; i < tokens.length; i++) {
                        if (j >= keys.length) {
                          break
                        }
                        var token = tokens[i]
                        if (typeof token === 'string' || token.content && typeof token.content === 'string') {
                          var k = keys[j]
                          var t = env.tokenStack[k]
                          var s = typeof token === 'string' ? token : token.content
                          var placeholder = getPlaceholder(language, k)
                          var index = s.indexOf(placeholder)
                          if (index > -1) {
                            ++j
                            var before = s.substring(0, index)
                            var middle = new Prism.Token(language, Prism.tokenize(t, env.grammar), 'language-' + language, t)
                            var after = s.substring(index + placeholder.length)
                            var replacement = []
                            if (before) {
                              replacement.push.apply(replacement, walkTokens([before]))
                            }
                            replacement.push(middle)
                            if (after) {
                              replacement.push.apply(replacement, walkTokens([after]))
                            }
                            if (typeof token === 'string') {
                              tokens.splice.apply(tokens, [
                                i,
                                1
                              ].concat(replacement))
                            } else {
                              token.content = replacement
                            }
                          }
                        } else if (token.content) {
                          walkTokens(token.content)
                        }
                      }
                      return tokens
                    }
                    walkTokens(env.tokens)
                  }
                }
              })
            }(Prism))
          },
          {}
        ],
        10: [
          function (require, module, exports) {
            Prism.languages.markup = {
              comment: /<!--[\s\S]*?-->/,
              prolog: /<\?[\s\S]+?\?>/,
              doctype: {
                pattern: /<!DOCTYPE(?:[^>"'[\]]|"[^"]*"|'[^']*')+(?:\[(?:[^<"'\]]|"[^"]*"|'[^']*'|<(?!!--)|<!--(?:[^-]|-(?!->))*-->)*\]\s*)?>/i,
                greedy: true,
                inside: {
                  'internal-subset': {
                    pattern: /(\[)[\s\S]+(?=\]>$)/,
                    lookbehind: true,
                    greedy: true,
                    inside: null
                  },
                  string: {
                    pattern: /"[^"]*"|'[^']*'/,
                    greedy: true
                  },
                  punctuation: /^<!|>$|[[\]]/,
                  'doctype-tag': /^DOCTYPE/,
                  name: /[^\s<>'"]+/
                }
              },
              cdata: /<!\[CDATA\[[\s\S]*?]]>/i,
              tag: {
                pattern: /<\/?(?!\d)[^\s>\/=$<%]+(?:\s(?:\s*[^\s>\/=]+(?:\s*=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))|(?=[\s/>])))+)?\s*\/?>/,
                greedy: true,
                inside: {
                  tag: {
                    pattern: /^<\/?[^\s>\/]+/,
                    inside: {
                      punctuation: /^<\/?/,
                      namespace: /^[^\s>\/:]+:/
                    }
                  },
                  'attr-value': {
                    pattern: /=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+)/,
                    inside: {
                      punctuation: [
                        {
                          pattern: /^=/,
                          alias: 'attr-equals'
                        },
                        /"|'/
                      ]
                    }
                  },
                  punctuation: /\/?>/,
                  'attr-name': {
                    pattern: /[^\s>\/]+/,
                    inside: { namespace: /^[^\s>\/:]+:/ }
                  }
                }
              },
              entity: [
                {
                  pattern: /&[\da-z]{1,8};/i,
                  alias: 'named-entity'
                },
                /&#x?[\da-f]{1,8};/i
              ]
            }
            Prism.languages.markup.tag.inside['attr-value'].inside.entity = Prism.languages.markup.entity
            Prism.languages.markup.doctype.inside['internal-subset'].inside = Prism.languages.markup
            Prism.hooks.add('wrap', function (env) {
              if (env.type === 'entity') {
                env.attributes.title = env.content.replace(/&amp;/, '&')
              }
            })
            Object.defineProperty(Prism.languages.markup.tag, 'addInlined', {
              value: function addInlined (tagName, lang) {
                var includedCdataInside = {}
                includedCdataInside['language-' + lang] = {
                  pattern: /(^<!\[CDATA\[)[\s\S]+?(?=\]\]>$)/i,
                  lookbehind: true,
                  inside: Prism.languages[lang]
                }
                includedCdataInside.cdata = /^<!\[CDATA\[|\]\]>$/i
                var inside = {
                  'included-cdata': {
                    pattern: /<!\[CDATA\[[\s\S]*?\]\]>/i,
                    inside: includedCdataInside
                  }
                }
                inside['language-' + lang] = {
                  pattern: /[\s\S]+/,
                  inside: Prism.languages[lang]
                }
                var def = {}
                def[tagName] = {
                  pattern: RegExp(/(<__[^>]*>)(?:<!\[CDATA\[(?:[^\]]|\](?!\]>))*\]\]>|(?!<!\[CDATA\[)[\s\S])*?(?=<\/__>)/.source.replace(/__/g, function () {
                    return tagName
                  }), 'i'),
                  lookbehind: true,
                  greedy: true,
                  inside: inside
                }
                Prism.languages.insertBefore('markup', 'cdata', def)
              }
            })
            Prism.languages.html = Prism.languages.markup
            Prism.languages.mathml = Prism.languages.markup
            Prism.languages.svg = Prism.languages.markup
            Prism.languages.xml = Prism.languages.extend('markup', {})
            Prism.languages.ssml = Prism.languages.xml
            Prism.languages.atom = Prism.languages.xml
            Prism.languages.rss = Prism.languages.xml
          },
          {}
        ],
        11: [
          function (require, module, exports) {
            (function (Prism) {
              var comment = /\/\*[\s\S]*?\*\/|\/\/.*|#(?!\[).*/
              var constant = [
                {
                  pattern: /\b(?:false|true)\b/i,
                  alias: 'boolean'
                },
                /\b[A-Z_][A-Z0-9_]*\b(?!\s*\()/,
                /\b(?:null)\b/i
              ]
              var number = /\b0b[01]+\b|\b0x[\da-f]+\b|(?:\b\d+(?:_\d+)*(?:\.(?:\d+(?:_\d+)*)?)?|\B\.\d+)(?:e[+-]?\d+)?/i
              var operator = /<?=>|\?\?=?|\.{3}|\??->|[!=]=?=?|::|\*\*=?|--|\+\+|&&|\|\||<<|>>|[?~]|[/^|%*&<>.+-]=?/
              var punctuation = /[{}\[\](),:;]/
              Prism.languages.php = {
                delimiter: {
                  pattern: /\?>$|^<\?(?:php(?=\s)|=)?/i,
                  alias: 'important'
                },
                comment: comment,
                variable: /\$+(?:\w+\b|(?={))/i,
                package: {
                  pattern: /(namespace\s+|use\s+(?:function\s+)?)(?:\\?\b[a-z_]\w*)+\b(?!\\)/i,
                  lookbehind: true,
                  inside: { punctuation: /\\/ }
                },
                keyword: [
                  {
                    pattern: /(\(\s*)\b(?:bool|boolean|int|integer|float|string|object|array)\b(?=\s*\))/i,
                    alias: 'type-casting',
                    greedy: true,
                    lookbehind: true
                  },
                  {
                    pattern: /([(,?]\s*)\b(?:bool|int|float|string|object|array(?!\s*\()|mixed|self|static|callable|iterable|(?:null|false)(?=\s*\|))\b(?=\s*\$)/i,
                    alias: 'type-hint',
                    greedy: true,
                    lookbehind: true
                  },
                  {
                    pattern: /([(,?]\s*[a-z0-9_|]\|\s*)(?:null|false)\b(?=\s*\$)/i,
                    alias: 'type-hint',
                    greedy: true,
                    lookbehind: true
                  },
                  {
                    pattern: /(\)\s*:\s*(?:\?\s*)?)\b(?:bool|int|float|string|object|void|array(?!\s*\()|mixed|self|static|callable|iterable|(?:null|false)(?=\s*\|))\b/i,
                    alias: 'return-type',
                    greedy: true,
                    lookbehind: true
                  },
                  {
                    pattern: /(\)\s*:\s*(?:\?\s*)?[a-z0-9_|]\|\s*)(?:null|false)\b/i,
                    alias: 'return-type',
                    greedy: true,
                    lookbehind: true
                  },
                  {
                    pattern: /\b(?:bool|int|float|string|object|void|array(?!\s*\()|mixed|iterable|(?:null|false)(?=\s*\|))\b/i,
                    alias: 'type-declaration',
                    greedy: true
                  },
                  {
                    pattern: /(\|\s*)(?:null|false)\b/i,
                    alias: 'type-declaration',
                    greedy: true,
                    lookbehind: true
                  },
                  {
                    pattern: /\b(?:parent|self|static)(?=\s*::)/i,
                    alias: 'static-context',
                    greedy: true
                  },
                  /\b(?:__halt_compiler|abstract|and|array|as|break|callable|case|catch|class|clone|const|continue|declare|default|die|do|echo|else|elseif|empty|enddeclare|endfor|endforeach|endif|endswitch|endwhile|eval|exit|extends|final|finally|for|foreach|function|global|goto|if|implements|include|include_once|instanceof|insteadof|interface|isset|list|namespace|match|new|or|parent|print|private|protected|public|require|require_once|return|self|static|switch|throw|trait|try|unset|use|var|while|xor|yield)\b/i
                ],
                'argument-name': /\b[a-z_]\w*(?=\s*:(?!:))/i,
                'class-name': [
                  {
                    pattern: /(\b(?:class|interface|extends|implements|trait|instanceof|new(?!\s+self|\s+static))\s+|\bcatch\s*\()\b[a-z_]\w*(?!\\)\b/i,
                    greedy: true,
                    lookbehind: true
                  },
                  {
                    pattern: /(\|\s*)\b[a-z_]\w*(?!\\)\b/i,
                    greedy: true,
                    lookbehind: true
                  },
                  {
                    pattern: /\b[a-z_]\w*(?!\\)\b(?=\s*\|)/i,
                    greedy: true
                  },
                  {
                    pattern: /(\|\s*)(?:\\?\b[a-z_]\w*)+\b/i,
                    alias: 'class-name-fully-qualified',
                    greedy: true,
                    lookbehind: true,
                    inside: { punctuation: /\\/ }
                  },
                  {
                    pattern: /(?:\\?\b[a-z_]\w*)+\b(?=\s*\|)/i,
                    alias: 'class-name-fully-qualified',
                    greedy: true,
                    inside: { punctuation: /\\/ }
                  },
                  {
                    pattern: /(\b(?:extends|implements|instanceof|new(?!\s+self\b|\s+static\b))\s+|\bcatch\s*\()(?:\\?\b[a-z_]\w*)+\b(?!\\)/i,
                    alias: 'class-name-fully-qualified',
                    greedy: true,
                    lookbehind: true,
                    inside: { punctuation: /\\/ }
                  },
                  {
                    pattern: /\b[a-z_]\w*(?=\s*\$)/i,
                    alias: 'type-declaration',
                    greedy: true
                  },
                  {
                    pattern: /(?:\\?\b[a-z_]\w*)+(?=\s*\$)/i,
                    alias: [
                      'class-name-fully-qualified',
                      'type-declaration'
                    ],
                    greedy: true,
                    inside: { punctuation: /\\/ }
                  },
                  {
                    pattern: /\b[a-z_]\w*(?=\s*::)/i,
                    alias: 'static-context',
                    greedy: true
                  },
                  {
                    pattern: /(?:\\?\b[a-z_]\w*)+(?=\s*::)/i,
                    alias: [
                      'class-name-fully-qualified',
                      'static-context'
                    ],
                    greedy: true,
                    inside: { punctuation: /\\/ }
                  },
                  {
                    pattern: /([(,?]\s*)[a-z_]\w*(?=\s*\$)/i,
                    alias: 'type-hint',
                    greedy: true,
                    lookbehind: true
                  },
                  {
                    pattern: /([(,?]\s*)(?:\\?\b[a-z_]\w*)+(?=\s*\$)/i,
                    alias: [
                      'class-name-fully-qualified',
                      'type-hint'
                    ],
                    greedy: true,
                    lookbehind: true,
                    inside: { punctuation: /\\/ }
                  },
                  {
                    pattern: /(\)\s*:\s*(?:\?\s*)?)\b[a-z_]\w*(?!\\)\b/i,
                    alias: 'return-type',
                    greedy: true,
                    lookbehind: true
                  },
                  {
                    pattern: /(\)\s*:\s*(?:\?\s*)?)(?:\\?\b[a-z_]\w*)+\b(?!\\)/i,
                    alias: [
                      'class-name-fully-qualified',
                      'return-type'
                    ],
                    greedy: true,
                    lookbehind: true,
                    inside: { punctuation: /\\/ }
                  }
                ],
                constant: constant,
                function: /\w+\s*(?=\()/,
                property: {
                  pattern: /(->)[\w]+/,
                  lookbehind: true
                },
                number: number,
                operator: operator,
                punctuation: punctuation
              }
              var string_interpolation = {
                pattern: /{\$(?:{(?:{[^{}]+}|[^{}]+)}|[^{}])+}|(^|[^\\{])\$+(?:\w+(?:\[[^\r\n\[\]]+\]|->\w+)*)/,
                lookbehind: true,
                inside: Prism.languages.php
              }
              var string = [
                {
                  pattern: /<<<'([^']+)'[\r\n](?:.*[\r\n])*?\1;/,
                  alias: 'nowdoc-string',
                  greedy: true,
                  inside: {
                    delimiter: {
                      pattern: /^<<<'[^']+'|[a-z_]\w*;$/i,
                      alias: 'symbol',
                      inside: { punctuation: /^<<<'?|[';]$/ }
                    }
                  }
                },
                {
                  pattern: /<<<(?:"([^"]+)"[\r\n](?:.*[\r\n])*?\1;|([a-z_]\w*)[\r\n](?:.*[\r\n])*?\2;)/i,
                  alias: 'heredoc-string',
                  greedy: true,
                  inside: {
                    delimiter: {
                      pattern: /^<<<(?:"[^"]+"|[a-z_]\w*)|[a-z_]\w*;$/i,
                      alias: 'symbol',
                      inside: { punctuation: /^<<<"?|[";]$/ }
                    },
                    interpolation: string_interpolation
                  }
                },
                {
                  pattern: /`(?:\\[\s\S]|[^\\`])*`/,
                  alias: 'backtick-quoted-string',
                  greedy: true
                },
                {
                  pattern: /'(?:\\[\s\S]|[^\\'])*'/,
                  alias: 'single-quoted-string',
                  greedy: true
                },
                {
                  pattern: /"(?:\\[\s\S]|[^\\"])*"/,
                  alias: 'double-quoted-string',
                  greedy: true,
                  inside: { interpolation: string_interpolation }
                }
              ]
              Prism.languages.insertBefore('php', 'variable', { string: string })
              Prism.languages.insertBefore('php', 'variable', {
                attribute: {
                  pattern: /#\[(?:[^"'\/#]|\/(?![*/])|\/\/.*$|#(?!\[).*$|\/\*(?:[^*]|\*(?!\/))*\*\/|"(?:\\[\s\S]|[^\\"])*"|'(?:\\[\s\S]|[^\\'])*')+\](?=\s*[a-z$#])/mi,
                  greedy: true,
                  inside: {
                    'attribute-content': {
                      pattern: /^(#\[)[\s\S]+(?=]$)/,
                      lookbehind: true,
                      inside: {
                        comment: comment,
                        string: string,
                        'attribute-class-name': [
                          {
                            pattern: /([^:]|^)\b[a-z_]\w*(?!\\)\b/i,
                            alias: 'class-name',
                            greedy: true,
                            lookbehind: true
                          },
                          {
                            pattern: /([^:]|^)(?:\\?\b[a-z_]\w*)+/i,
                            alias: [
                              'class-name',
                              'class-name-fully-qualified'
                            ],
                            greedy: true,
                            lookbehind: true,
                            inside: { punctuation: /\\/ }
                          }
                        ],
                        constant: constant,
                        number: number,
                        operator: operator,
                        punctuation: punctuation
                      }
                    },
                    delimiter: {
                      pattern: /^#\[|]$/,
                      alias: 'punctuation'
                    }
                  }
                }
              })
              Prism.hooks.add('before-tokenize', function (env) {
                if (!/<\?/.test(env.code)) {
                  return
                }
                var phpPattern = /<\?(?:[^"'/#]|\/(?![*/])|("|')(?:\\[\s\S]|(?!\1)[^\\])*\1|(?:\/\/|#(?!\[))(?:[^?\n\r]|\?(?!>))*(?=$|\?>|[\r\n])|#\[|\/\*(?:[^*]|\*(?!\/))*(?:\*\/|$))*?(?:\?>|$)/ig
                Prism.languages['markup-templating'].buildPlaceholders(env, 'php', phpPattern)
              })
              Prism.hooks.add('after-tokenize', function (env) {
                Prism.languages['markup-templating'].tokenizePlaceholders(env, 'php')
              })
            }(Prism))
          },
          {}
        ],
        12: [
          function (require, module, exports) {
            Prism.languages.python = {
              comment: {
                pattern: /(^|[^\\])#.*/,
                lookbehind: true
              },
              'string-interpolation': {
                pattern: /(?:f|rf|fr)(?:("""|''')[\s\S]*?\1|("|')(?:\\.|(?!\2)[^\\\r\n])*\2)/i,
                greedy: true,
                inside: {
                  interpolation: {
                    pattern: /((?:^|[^{])(?:{{)*){(?!{)(?:[^{}]|{(?!{)(?:[^{}]|{(?!{)(?:[^{}])+})+})+}/,
                    lookbehind: true,
                    inside: {
                      'format-spec': {
                        pattern: /(:)[^:(){}]+(?=}$)/,
                        lookbehind: true
                      },
                      'conversion-option': {
                        pattern: /![sra](?=[:}]$)/,
                        alias: 'punctuation'
                      },
                      rest: null
                    }
                  },
                  string: /[\s\S]+/
                }
              },
              'triple-quoted-string': {
                pattern: /(?:[rub]|rb|br)?("""|''')[\s\S]*?\1/i,
                greedy: true,
                alias: 'string'
              },
              string: {
                pattern: /(?:[rub]|rb|br)?("|')(?:\\.|(?!\1)[^\\\r\n])*\1/i,
                greedy: true
              },
              function: {
                pattern: /((?:^|\s)def[ \t]+)[a-zA-Z_]\w*(?=\s*\()/g,
                lookbehind: true
              },
              'class-name': {
                pattern: /(\bclass\s+)\w+/i,
                lookbehind: true
              },
              decorator: {
                pattern: /(^\s*)@\w+(?:\.\w+)*/im,
                lookbehind: true,
                alias: [
                  'annotation',
                  'punctuation'
                ],
                inside: { punctuation: /\./ }
              },
              keyword: /\b(?:and|as|assert|async|await|break|class|continue|def|del|elif|else|except|exec|finally|for|from|global|if|import|in|is|lambda|nonlocal|not|or|pass|print|raise|return|try|while|with|yield)\b/,
              builtin: /\b(?:__import__|abs|all|any|apply|ascii|basestring|bin|bool|buffer|bytearray|bytes|callable|chr|classmethod|cmp|coerce|compile|complex|delattr|dict|dir|divmod|enumerate|eval|execfile|file|filter|float|format|frozenset|getattr|globals|hasattr|hash|help|hex|id|input|int|intern|isinstance|issubclass|iter|len|list|locals|long|map|max|memoryview|min|next|object|oct|open|ord|pow|property|range|raw_input|reduce|reload|repr|reversed|round|set|setattr|slice|sorted|staticmethod|str|sum|super|tuple|type|unichr|unicode|vars|xrange|zip)\b/,
              boolean: /\b(?:True|False|None)\b/,
              number: /(?:\b(?=\d)|\B(?=\.))(?:0[bo])?(?:(?:\d|0x[\da-f])[\da-f]*(?:\.\d*)?|\.\d+)(?:e[+-]?\d+)?j?\b/i,
              operator: /[-+%=]=?|!=|\*\*?=?|\/\/?=?|<[<=>]?|>[=>]?|[&|^~]/,
              punctuation: /[{}[\];(),.:]/
            }
            Prism.languages.python['string-interpolation'].inside.interpolation.inside.rest = Prism.languages.python
            Prism.languages.py = Prism.languages.python
          },
          {}
        ],
        13: [
          function (require, module, exports) {
            (function (Prism) {
              Prism.languages.ruby = Prism.languages.extend('clike', {
                comment: [
                  /#.*/,
                  {
                    pattern: /^=begin\s[\s\S]*?^=end/m,
                    greedy: true
                  }
                ],
                'class-name': {
                  pattern: /(\b(?:class)\s+|\bcatch\s+\()[\w.\\]+/i,
                  lookbehind: true,
                  inside: { punctuation: /[.\\]/ }
                },
                keyword: /\b(?:alias|and|BEGIN|begin|break|case|class|def|define_method|defined|do|each|else|elsif|END|end|ensure|extend|for|if|in|include|module|new|next|nil|not|or|prepend|protected|private|public|raise|redo|require|rescue|retry|return|self|super|then|throw|undef|unless|until|when|while|yield)\b/
              })
              var interpolation = {
                pattern: /#\{[^}]+\}/,
                inside: {
                  delimiter: {
                    pattern: /^#\{|\}$/,
                    alias: 'tag'
                  },
                  rest: Prism.languages.ruby
                }
              }
              delete Prism.languages.ruby.function
              Prism.languages.insertBefore('ruby', 'keyword', {
                regex: [
                  {
                    pattern: RegExp(/%r/.source + '(?:' + [
                      /([^a-zA-Z0-9\s{(\[<])(?:(?!\1)[^\\]|\\[\s\S])*\1[gim]{0,3}/.source,
                      /\((?:[^()\\]|\\[\s\S])*\)[gim]{0,3}/.source,
                      /\{(?:[^#{}\\]|#(?:\{[^}]+\})?|\\[\s\S])*\}[gim]{0,3}/.source,
                      /\[(?:[^\[\]\\]|\\[\s\S])*\][gim]{0,3}/.source,
                      /<(?:[^<>\\]|\\[\s\S])*>[gim]{0,3}/.source
                    ].join('|') + ')'),
                    greedy: true,
                    inside: { interpolation: interpolation }
                  },
                  {
                    pattern: /(^|[^/])\/(?!\/)(?:\[[^\r\n\]]+\]|\\.|[^[/\\\r\n])+\/[gim]{0,3}(?=\s*(?:$|[\r\n,.;})]))/,
                    lookbehind: true,
                    greedy: true
                  }
                ],
                variable: /[@$]+[a-zA-Z_]\w*(?:[?!]|\b)/,
                symbol: {
                  pattern: /(^|[^:]):[a-zA-Z_]\w*(?:[?!]|\b)/,
                  lookbehind: true
                },
                'method-definition': {
                  pattern: /(\bdef\s+)[\w.]+/,
                  lookbehind: true,
                  inside: {
                    function: /\w+$/,
                    rest: Prism.languages.ruby
                  }
                }
              })
              Prism.languages.insertBefore('ruby', 'number', {
                builtin: /\b(?:Array|Bignum|Binding|Class|Continuation|Dir|Exception|FalseClass|File|Stat|Fixnum|Float|Hash|Integer|IO|MatchData|Method|Module|NilClass|Numeric|Object|Proc|Range|Regexp|String|Struct|TMS|Symbol|ThreadGroup|Thread|Time|TrueClass)\b/,
                constant: /\b[A-Z]\w*(?:[?!]|\b)/
              })
              Prism.languages.ruby.string = [
                {
                  pattern: RegExp(/%[qQiIwWxs]?/.source + '(?:' + [
                    /([^a-zA-Z0-9\s{(\[<])(?:(?!\1)[^\\]|\\[\s\S])*\1/.source,
                    /\((?:[^()\\]|\\[\s\S])*\)/.source,
                    /\{(?:[^#{}\\]|#(?:\{[^}]+\})?|\\[\s\S])*\}/.source,
                    /\[(?:[^\[\]\\]|\\[\s\S])*\]/.source,
                    /<(?:[^<>\\]|\\[\s\S])*>/.source
                  ].join('|') + ')'),
                  greedy: true,
                  inside: { interpolation: interpolation }
                },
                {
                  pattern: /("|')(?:#\{[^}]+\}|#(?!\{)|\\(?:\r\n|[\s\S])|(?!\1)[^\\#\r\n])*\1/,
                  greedy: true,
                  inside: { interpolation: interpolation }
                }
              ]
              Prism.languages.rb = Prism.languages.ruby
            }(Prism))
          },
          {}
        ],
        14: [
          function (require, module, exports) {
            var Prism = require('prismjs/components/prism-core')
            require('prismjs/components/prism-clike')
            require('prismjs/components/prism-markup-templating')
            require('prismjs/components/prism-c')
            require('prismjs/components/prism-cpp')
            require('prismjs/components/prism-csharp')
            require('prismjs/components/prism-css')
            require('prismjs/components/prism-java')
            require('prismjs/components/prism-javascript')
            require('prismjs/components/prism-markup')
            require('prismjs/components/prism-php')
            require('prismjs/components/prism-python')
            require('prismjs/components/prism-ruby')
            module.exports = { boltExport: Prism }
          },
          {
            'prismjs/components/prism-c': 1,
            'prismjs/components/prism-clike': 2,
            'prismjs/components/prism-core': 3,
            'prismjs/components/prism-cpp': 4,
            'prismjs/components/prism-csharp': 5,
            'prismjs/components/prism-css': 6,
            'prismjs/components/prism-java': 7,
            'prismjs/components/prism-javascript': 8,
            'prismjs/components/prism-markup': 10,
            'prismjs/components/prism-markup-templating': 9,
            'prismjs/components/prism-php': 11,
            'prismjs/components/prism-python': 12,
            'prismjs/components/prism-ruby': 13
          }
        ]
      }, {}, [14])(14)
    }))
    var prism = window.Prism
    window.Prism = oldprism
    return prism
  }(undefined, exports$1, module, undefined))
  var Prism$1 = module.exports.boltExport

  var getLanguages = function (editor) {
    return editor.getParam('codesample_languages')
  }
  var useGlobalPrismJS = function (editor) {
    return editor.getParam('codesample_global_prismjs', false, 'boolean')
  }

  var get$1 = function (editor) {
    return Global.Prism && useGlobalPrismJS(editor) ? Global.Prism : Prism$1
  }

  var getSelectedCodeSample = function (editor) {
    var node = editor.selection ? editor.selection.getNode() : null
    if (isCodeSample(node)) {
      return Optional.some(node)
    }
    return Optional.none()
  }
  var insertCodeSample = function (editor, language, code) {
    editor.undoManager.transact(function () {
      var node = getSelectedCodeSample(editor)
      code = global$1.DOM.encode(code)
      return node.fold(function () {
        editor.insertContent('<pre id="__new" class="language-' + language + '">' + code + '</pre>')
        editor.selection.select(editor.$('#__new').removeAttr('id')[0])
      }, function (n) {
        editor.dom.setAttrib(n, 'class', 'language-' + language)
        n.innerHTML = code
        get$1(editor).highlightElement(n)
        editor.selection.select(n)
      })
    })
  }
  var getCurrentCode = function (editor) {
    var node = getSelectedCodeSample(editor)
    return node.fold(function () {
      return ''
    }, function (n) {
      return n.textContent
    })
  }

  var getLanguages$1 = function (editor) {
    var defaultLanguages = [
      {
        text: 'HTML/XML',
        value: 'markup'
      },
      {
        text: 'JavaScript',
        value: 'javascript'
      },
      {
        text: 'CSS',
        value: 'css'
      },
      {
        text: 'PHP',
        value: 'php'
      },
      {
        text: 'Ruby',
        value: 'ruby'
      },
      {
        text: 'Python',
        value: 'python'
      },
      {
        text: 'Java',
        value: 'java'
      },
      {
        text: 'C',
        value: 'c'
      },
      {
        text: 'C#',
        value: 'csharp'
      },
      {
        text: 'C++',
        value: 'cpp'
      }
    ]
    var customLanguages = getLanguages(editor)
    return customLanguages || defaultLanguages
  }
  var getCurrentLanguage = function (editor, fallback) {
    var node = getSelectedCodeSample(editor)
    return node.fold(function () {
      return fallback
    }, function (n) {
      var matches = n.className.match(/language-(\w+)/)
      return matches ? matches[1] : fallback
    })
  }

  var open = function (editor) {
    var languages = getLanguages$1(editor)
    var defaultLanguage = head(languages).fold(function () {
      return ''
    }, function (l) {
      return l.value
    })
    var currentLanguage = getCurrentLanguage(editor, defaultLanguage)
    var currentCode = getCurrentCode(editor)
    editor.windowManager.open({
      title: 'Insert/Edit Code Sample',
      size: 'large',
      body: {
        type: 'panel',
        items: [
          {
            type: 'selectbox',
            name: 'language',
            label: 'Language',
            items: languages
          },
          {
            type: 'textarea',
            name: 'code',
            label: 'Code view'
          }
        ]
      },
      buttons: [
        {
          type: 'cancel',
          name: 'cancel',
          text: 'Cancel'
        },
        {
          type: 'submit',
          name: 'save',
          text: 'Save',
          primary: true
        }
      ],
      initialData: {
        language: currentLanguage,
        code: currentCode
      },
      onSubmit: function (api) {
        var data = api.getData()
        insertCodeSample(editor, data.language, data.code)
        api.close()
      }
    })
  }

  var register = function (editor) {
    editor.addCommand('codesample', function () {
      var node = editor.selection.getNode()
      if (editor.selection.isCollapsed() || isCodeSample(node)) {
        open(editor)
      } else {
        editor.formatter.toggle('code')
      }
    })
  }

  var setup = function (editor) {
    var $ = editor.$
    editor.on('PreProcess', function (e) {
      $('pre[contenteditable=false]', e.node).filter(trimArg(isCodeSample)).each(function (idx, elm) {
        var $elm = $(elm); var code = elm.textContent
        $elm.attr('class', $.trim($elm.attr('class')))
        $elm.removeAttr('contentEditable')
        $elm.empty().append($('<code></code>').each(function () {
          this.textContent = code
        }))
      })
    })
    editor.on('SetContent', function () {
      var unprocessedCodeSamples = $('pre').filter(trimArg(isCodeSample)).filter(function (idx, elm) {
        return elm.contentEditable !== 'false'
      })
      if (unprocessedCodeSamples.length) {
        editor.undoManager.transact(function () {
          unprocessedCodeSamples.each(function (idx, elm) {
            $(elm).find('br').each(function (idx, elm) {
              elm.parentNode.replaceChild(editor.getDoc().createTextNode('\n'), elm)
            })
            elm.contentEditable = 'false'
            elm.innerHTML = editor.dom.encode(elm.textContent)
            get$1(editor).highlightElement(elm)
            elm.className = $.trim(elm.className)
          })
        })
      }
    })
  }

  var isCodeSampleSelection = function (editor) {
    var node = editor.selection.getStart()
    return editor.dom.is(node, 'pre[class*="language-"]')
  }
  var register$1 = function (editor) {
    editor.ui.registry.addToggleButton('codesample', {
      icon: 'code-sample',
      tooltip: 'Insert/edit code sample',
      onAction: function () {
        return open(editor)
      },
      onSetup: function (api) {
        var nodeChangeHandler = function () {
          api.setActive(isCodeSampleSelection(editor))
        }
        editor.on('NodeChange', nodeChangeHandler)
        return function () {
          return editor.off('NodeChange', nodeChangeHandler)
        }
      }
    })
    editor.ui.registry.addMenuItem('codesample', {
      text: 'Code sample...',
      icon: 'code-sample',
      onAction: function () {
        return open(editor)
      }
    })
  }

  function Plugin () {
    global.add('codesample', function (editor) {
      setup(editor)
      register$1(editor)
      register(editor)
      editor.on('dblclick', function (ev) {
        if (isCodeSample(ev.target)) {
          open(editor)
        }
      })
    })
  }

  Plugin()
}())
